Clojure Applied (for Embach Mark) by Ben Vandgrift Alex Miller
Author:Ben Vandgrift, Alex Miller
Language: eng
Format: epub
Tags: Pragmatic Bookshelf
ISBN: 978-1-68050-074-5
Publisher: The Pragmatic Bookshelf, LLC (573151)
Go Blocks
Traditionally, Java (or Clojure) programs create threads (which map to real operating-system threads) to contain the actual processing for each part of the program. The core.async library follows a different tradition, based on the heritage of C. A. R. Hoare’s classic work on Communicating Sequential Processes (CSP) [Hoa78].[19]
We won’t dive into the details of that work. The important thing is learning to think in a different way about how we structure programs. Threads are scarce and expensive resources. They consume stack space and other resources, and they’re comparatively slow to start. When these threads block for I/O, we waste those system resources.
Instead, core.async encourages us to think in terms of lightweight processes that are mapped to a thread pool and run only when work is ready to be done. Instead of blocking while waiting for messages to go in or out on channels, those processes can be parked until the process is ready to run again. This allows us to run processes only when there’s work to do. Also, it allows us to implement some interesting new behavior for selecting across multiple I/O operations and proceeding when the first one completes.
In core.async, we call these processes go blocks (in a nod to similar concepts in the Go language). Inside go blocks we use channels, though the put and take operations are <! and >!.
Here’s an example of a function that creates a go block to receive and process messages by printing them:
(require '[clojure.core.async :refer (go <!)])
Download
This site does not store any files on its server. We only index and link to content provided by other sites. Please contact the content providers to delete copyright contents if any and email us, we'll remove relevant links or contents immediately.
Deep Learning with Python by François Chollet(12568)
Hello! Python by Anthony Briggs(9913)
OCA Java SE 8 Programmer I Certification Guide by Mala Gupta(9795)
The Mikado Method by Ola Ellnestam Daniel Brolund(9777)
Dependency Injection in .NET by Mark Seemann(9337)
Algorithms of the Intelligent Web by Haralambos Marmanis;Dmitry Babenko(8295)
Test-Driven iOS Development with Swift 4 by Dominik Hauser(7763)
Grails in Action by Glen Smith Peter Ledbrook(7696)
The Well-Grounded Java Developer by Benjamin J. Evans Martijn Verburg(7557)
Becoming a Dynamics 365 Finance and Supply Chain Solution Architect by Brent Dawson(7054)
Microservices with Go by Alexander Shuiskov(6817)
Practical Design Patterns for Java Developers by Miroslav Wengner(6734)
Test Automation Engineering Handbook by Manikandan Sambamurthy(6675)
Secrets of the JavaScript Ninja by John Resig Bear Bibeault(6409)
Angular Projects - Third Edition by Aristeidis Bampakos(6080)
The Art of Crafting User Stories by The Art of Crafting User Stories(5607)
NetSuite for Consultants - Second Edition by Peter Ries(5547)
Demystifying Cryptography with OpenSSL 3.0 by Alexei Khlebnikov(5347)
Kotlin in Action by Dmitry Jemerov(5062)
